## 3. Conditional Branch Summary

| Test     | Boolean       | Mnemonic            | Complementar<br>y | Boolean          | Mnemonic  | Comment  |
|----------|---------------|---------------------|-------------------|------------------|-----------|----------|
| Rd > Rr  | Z•(N ⊕ V) = 0 | BRLT <sup>(1)</sup> | Rd ≤ Rr           | Z+(N ⊕ V) =<br>1 | BRGE*     | Signed   |
| Rd ≥ Rr  | (N ⊕ V) = 0   | BRGE                | Rd < Rr           | (N ⊕ V) = 1      | BRLT      | Signed   |
| Rd = Rr  | Z = 1         | BREQ                | Rd ≠ Rr           | Z = 0            | BRNE      | Signed   |
| Rd ≤ Rr  | Z+(N + V) = 1 | BRGE <sup>(1)</sup> | Rd > Rr           | Z•(N ⊕ V) = 0    | BRLT*     | Signed   |
| Rd < Rr  | (N ⊕ V) = 1   | BRLT                | Rd ≥ Rr           | (N ⊕ V) = 0      | BRGE      | Signed   |
| Rd > Rr  | C + Z = 0     | BRLO <sup>(1)</sup> | Rd ≤ Rr           | C + Z = 1        | BRSH*     | Unsigned |
| Rd ≥ Rr  | C = 0         | BRSH/<br>BRCC       | Rd < Rr           | C = 1            | BRLO/BRCS | Unsigned |
| Rd = Rr  | Z = 1         | BREQ                | Rd ≠ Rr           | Z = 0            | BRNE      | Unsigned |
| Rd ≤ Rr  | C + Z = 1     | BRSH <sup>(1)</sup> | Rd > Rr           | C + Z = 0        | BRLO*     | Unsigned |
| Rd < Rr  | C = 1         | BRLO/BRCS           | Rd ≥ Rr           | C = 0            | BRSH/BRCC | Unsigned |
| Carry    | C = 1         | BRCS                | No carry          | C = 0            | BRCC      | Simple   |
| Negative | N = 1         | BRMI                | Positive          | N = 0            | BRPL      | Simple   |
| Overflow | V = 1         | BRVS                | No overflow       | V = 0            | BRVC      | Simple   |
| Zero     | Z = 1         | BREQ                | Not zero          | Z = 0            | BRNE      | Simple   |

**Note:** Interchange Rd and Rr in the operation before the test, i.e., CP Rd,Rr  $\rightarrow$  CP Rr,Rd.

Table 4-2. Arithmetic and Logic Instructions

| Mnemonic | Operands | Description                         |           | Ор       |               | Flags       | #Clocks<br>AVR | #Clocks<br>AVRxm | #Clocks<br>AVRxt | #Clocks<br>AVRrc |
|----------|----------|-------------------------------------|-----------|----------|---------------|-------------|----------------|------------------|------------------|------------------|
| ADD      | Rd, Rr   | Add without<br>Carry                | Rd        | ←        | Rd + Rr       | Z,C,N,V,S,H | 1              | 1                | 1                | 1                |
| ADC      | Rd, Rr   | Add with<br>Carry                   | Rd        | ←        | Rd + Rr + C   | Z,C,N,V,S,H | 1              | 1                | 1                | 1                |
| ADIW     | Rd, K    | Add<br>Immediate to<br>Word         | Rd        | <b>←</b> | Rd + 1:Rd + K | Z,C,N,V,S   | 2              | 2                | 2                | N/A              |
| SUB      | Rd, Rr   | Subtract without Carry              | Rd        | <b>←</b> | Rd - Rr       | Z,C,N,V,S,H | 1              | 1                | 1                | 1                |
| SUBI     | Rd, K    | Subtract<br>Immediate               | Rd        | <b>←</b> | Rd - K        | Z,C,N,V,S,H | 1              | 1                | 1                | 1                |
| SBC      | Rd, Rr   | Subtract with Carry                 | Rd        | <b>←</b> | Rd - Rr - C   | Z,C,N,V,S,H | 1              | 1                | 1                | 1                |
| SBCI     | Rd, K    | Subtract<br>Immediate<br>with Carry | Rd        | <b>←</b> | Rd - K - C    | Z,C,N,V,S,H | 1              | 1                | 1                | 1                |
| SBIW     | Rd, K    | Subtract<br>Immediate<br>from Word  | Rd + 1:Rd | ←        | Rd + 1:Rd - K | Z,C,N,V,S   | 2              | 2                | 2                | N/A              |
| AND      | Rd, Rr   | Logical AND                         | Rd        | ←        | Rd • Rr       | Z,N,V,S     | 1              | 1                | 1                | 1                |

| Mnemonic | Operands | Description                         |       | Ор       |                     | Flags       | #Clocks<br>AVR | #Clocks<br>AVRxm | #Clocks<br>AVRxt | #Clocks<br>AVRrc |
|----------|----------|-------------------------------------|-------|----------|---------------------|-------------|----------------|------------------|------------------|------------------|
| ANDI     | Rd, K    | Logical AND with Immediate          | Rd    | ←        | Rd • K              | Z,N,V,S     | 1              | 1                | 1                | 1                |
| OR       | Rd, Rr   | Logical OR                          | Rd    | <b>←</b> | Rd v Rr             | Z,N,V,S     | 1              | 1                | 1                | 1                |
| ORI      | Rd, K    | Logical OR with Immediate           | Rd    | <b>←</b> | Rd v K              | Z,N,V,S     | 1              | 1                | 1                | 1                |
| EOR      | Rd, Rr   | Exclusive OR                        | Rd    | ←        | Rd ⊕ Rr             | Z,N,V,S     | 1              | 1                | 1                | 1                |
| СОМ      | Rd       | One's<br>Complement                 | Rd    | <b>←</b> | \$FF - Rd           | Z,C,N,V,S   | 1              | 1                | 1                | 1                |
| NEG      | Rd       | Two's<br>Complement                 | Rd    | <b>←</b> | \$00 - Rd           | Z,C,N,V,S,H | 1              | 1                | 1                | 1                |
| SBR      | Rd,K     | Set Bit(s) in<br>Register           | Rd    | <b>←</b> | Rd v K              | Z,N,V,S     | 1              | 1                | 1                | 1                |
| CBR      | Rd,K     | Clear Bit(s) in<br>Register         | Rd    | <b>←</b> | Rd • (\$FFh -<br>K) | Z,N,V,S     | 1              | 1                | 1                | 1                |
| INC      | Rd       | Increment                           | Rd    | ←        | Rd + 1              | Z,N,V,S     | 1              | 1                | 1                | 1                |
| DEC      | Rd       | Decrement                           | Rd    | ←        | Rd - 1              | Z,N,V,S     | 1              | 1                | 1                | 1                |
| TST      | Rd       | Test for Zero or Minus              | Rd    | <b>←</b> | Rd • Rd             | Z,N,V,S     | 1              | 1                | 1                | 1                |
| CLR      | Rd       | Clear Register                      | Rd    | ←        | Rd ⊕ Rd             | Z,N,V,S     | 1              | 1                | 1                | 1                |
| SER      | Rd       | Set Register                        | Rd    | <b>←</b> | \$FF                | None        | 1              | 1                | 1                | 1                |
| MUL      | Rd,Rr    | Multiply<br>Unsigned                | R1:R0 | <b>←</b> | Rd x Rr (UU)        | Z,C         | 2              | 2                | 2                | N/A              |
| MULS     | Rd,Rr    | Multiply<br>Signed                  | R1:R0 | <b>←</b> | Rd x Rr (SS)        | Z,C         | 2              | 2                | 2                | N/A              |
| MULSU    | Rd,Rr    | Multiply<br>Signed with<br>Unsigned | R1:R0 | <b>←</b> | Rd x Rr (SU)        | Z,C         | 2              | 2                | 2                | N/A              |

Table 4-4. Data Transfer Instructions

| Mnemonic | Operands | Description                             |         | Ор         |              | Flags | #Clocks<br>AVR   | #Clocks<br>AVRxm        | #Clocks<br>AVRxt | #Clocks<br>AVRrc |
|----------|----------|-----------------------------------------|---------|------------|--------------|-------|------------------|-------------------------|------------------|------------------|
| MOV      | Rd, Rr   | Copy Register                           | Rd      | ←          | Rr           | None  | 1                | 1                       | 1                | 1                |
| MOVW     | Rd, Rr   | Copy Register<br>Pair                   | Rd+1:Rd | <b>←</b>   | Rr+1:Rr      | None  | 1                | 1                       | 1                | N/A              |
| LDI      | Rd, K    | Load<br>Immediate                       | Rd      | <b>←</b>   | К            | None  | 1                | 1                       | 1                | 1                |
| LDS      | Rd, k    | Load Direct from data space             | Rd      | <b>←</b>   | (k)          | None  | 2 <sup>(1)</sup> | 2 <sup>(1)</sup>        | 3 <sup>(1)</sup> | 2                |
| LD       | Rd, X    | Load Indirect                           | Rd      | ←          | (X)          | None  | 2 <sup>(1)</sup> | 1(1)                    | 2 <sup>(1)</sup> | 1/2              |
| LD       | Rd, X+   | Load Indirect<br>and Post-<br>Increment | Rd<br>X | <b>←</b>   | (X)<br>X + 1 | None  | 2 <sup>(1)</sup> | <b>1</b> <sup>(1)</sup> | 2 <sup>(1)</sup> | 2/3              |
| LD       | Rd, -X   | Load Indirect<br>and Pre-<br>Decrement  | X<br>Rd | <b>← ←</b> | X - 1<br>(X) | None  | 2 <sup>(1)</sup> | 2 <sup>(1)</sup>        | 2 <sup>(1)</sup> | 2/3              |
| LD       | Rd, Y    | Load Indirect                           | Rd      | ←          | (Y)          | None  | 2(1)             | 1(1)                    | 2 <sup>(1)</sup> | 1/2              |

Table 4-3. Branch Instructions

| Mnemonic | Operands | Description             |                       | Ор     |            | Flags | #Clocks<br>AVR | #Clocks<br>AVRxm | #Clocks<br>AVRxt | #Clocks<br>AVRrc |
|----------|----------|-------------------------|-----------------------|--------|------------|-------|----------------|------------------|------------------|------------------|
| RJMP     | k        | Relative Jump           | PC                    | ←      | PC + k + 1 | None  | 2              | 2                | 2                | 2                |
| IJMP     |          | Indirect Jump<br>to (Z) | PC(15:0)<br>PC(21:16) | ←<br>← | Z<br>0     | None  | 2              | 2                | 2                | 2                |



Atmel AVR Instruction Set Manual [OTHER]

Atmel-0856L-AVR-Instruction-Set-Manual\_Other-11/2016

| Mnemonic | Operands | Description                               |                             | Ор         |             | Flags       | #Clocks<br>AVR       | #Clocks<br>AVRxm   | #Clocks<br>AVRxt | #Clocks<br>AVRrc |
|----------|----------|-------------------------------------------|-----------------------------|------------|-------------|-------------|----------------------|--------------------|------------------|------------------|
| EIJMP    |          | Extended<br>Indirect Jump<br>to (Z)       | PC(15:0)<br>PC(21:16)       | <b>← ←</b> | Z<br>EIND   | None        | 2                    | 2                  | 2                | N/A              |
| JMP      | k        | Jump                                      | PC                          | <b>←</b>   | k           | None        | 3                    | 3                  | 3                | N/A              |
| RCALL    | k        | Relative Call<br>Subroutine               | PC                          | <b>←</b>   | PC + k + 1  | None        | 3/4(1)               | 2/3(1)             | 2/3              | 3 <sup>(1)</sup> |
| ICALL    |          | Indirect Call to                          | PC(15:0)                    | <b>←</b>   | Z           | None        | 3/4 <sup>(1)</sup>   | 2/3 <sup>(1)</sup> | 2/3              | 3 <sup>(1)</sup> |
| EICALL   |          | Extended<br>Indirect Call to<br>(Z)       | PC(15:0)<br>PC(21:16)       | <b>← ←</b> | Z<br>EIND   | None        | 4 <sup>(1)</sup>     | 3 <sup>(1)</sup>   | 2/3              | N/A              |
| CALL     | k        | Call<br>Subroutine                        | PC                          | ← 1        | k           | None        | 4 / 5 <sup>(1)</sup> | 3/4 <sup>(1)</sup> | 3/4              | N/A              |
| RET      |          | Subroutine<br>Return                      | PC                          | <b>←</b>   | STACK       | None        | 4 / 5(1)             | 4 / 5(1)           | 4/5              | 6 <sup>(1)</sup> |
| RETI     |          | Interrupt<br>Return                       | PC                          | ←          | STACK       | 1           | 4 / 5(1)             | 4/5(1)             | 4/5              | 6 <sup>(1)</sup> |
| CPSE     | Rd,Rr    | Compare,<br>skip if Equal                 | if (Rd = Rr)<br>PC          | <b>←</b>   | PC + 2 or 3 | None        | 1/2/3                | 1/2/3              | 1/2/3            | 1/2              |
| СР       | Rd,Rr    | Compare                                   | Rd - Rr                     |            |             | Z,C,N,V,S,H | 1                    | 1                  | 1                | 1                |
| CPC      | Rd,Rr    | Compare with Carry                        | Rd - Rr - C                 |            |             | Z,C,N,V,S,H | 1                    | 1                  | 1                | 1                |
| CPI      | Rd,K     | Compare with<br>Immediate                 | Rd - K                      |            |             | Z,C,N,V,S,H | 1                    | 1                  | 1                | 1                |
| SBRC     | Rr, b    | Skip if Bit in<br>Register<br>Cleared     | if (Rr(b) = 0)<br>PC        | ←          | PC + 2 or 3 | None        | 1/2/3                | 1/2/3              | 1/2/3            | 1/2              |
| SBRS     | Rr, b    | Skip if Bit in<br>Register Set            | if (Rr(b) = 1)<br>PC        | <b>←</b>   | PC + 2 or 3 | None        | 1/2/3                | 1/2/3              | 1/2/3            | 1/2              |
| SBIC     | A, b     | Skip if Bit in<br>I/O Register<br>Cleared | if (I/O(A,b) =<br>0) PC     | <b>←</b>   | PC + 2 or 3 | None        | 1/2/3                | 2/3/4              | 1/2/3            | 1/2              |
| SBIS     | A, b     | Skip if Bit in<br>I/O Register<br>Set     | If (I/O(A,b) =1) PC         | ←          | PC + 2 or 3 | None        | 1/2/3                | 2/3/4              | 1/2/3            | 1/2              |
| BRBS     | s, k     | Branch if<br>Status Flag<br>Set           | if (SREG(s) =<br>1) then PC | <b>←</b>   | PC + k + 1  | None        | 1/2                  | 1/2                | 1/2              | 1/2              |

23

| BREQ | k | Branch if Equal                | if (Z = 1) then<br>PC | <b>←</b> | PC + k + 1 | None | 1/2 | 1/2 | 1/2 | 1/2 |
|------|---|--------------------------------|-----------------------|----------|------------|------|-----|-----|-----|-----|
| BRNE | k | Branch if Not<br>Equal         | if (Z = 0) then<br>PC | <b>←</b> | PC + k + 1 | None | 1/2 | 1/2 | 1/2 | 1/2 |
| BRCS | k | Branch if<br>Carry Set         | if (C = 1) then<br>PC | <b>←</b> | PC + k + 1 | None | 1/2 | 1/2 | 1/2 | 1/2 |
| BRCC | k | Branch if<br>Carry Cleared     | if (C = 0) then<br>PC | <b>←</b> | PC + k + 1 | None | 1/2 | 1/2 | 1/2 | 1/2 |
| BRSH | k | Branch if<br>Same or<br>Higher | if (C = 0) then<br>PC | <b>←</b> | PC + k + 1 | None | 1/2 | 1/2 | 1/2 | 1/2 |



## Atmel AVR Instruction Set Manual [OTHER]

Atmel-0856L-AVR-Instruction-Set-Manual\_Other-11/2016

| Mnemonic | Operands | Description        |                       | Ор       |            | Flags | #Clocks<br>AVR | #Clocks<br>AVRxm | #Clocks<br>AVRxt | #Clocks<br>AVRrc |
|----------|----------|--------------------|-----------------------|----------|------------|-------|----------------|------------------|------------------|------------------|
| BRLO     | k        | Branch if<br>Lower | if (C = 1) then<br>PC | <b>←</b> | PC + k + 1 | None  | 1/2            | 1/2              | 1/2              | 1/2              |
| BRMI     | k        | Branch if<br>Minus | if (N = 1) then       | ←        | PC + k + 1 | None  | 1/2            | 1/2              | 1/2              | 1/2              |

| BRPL | k | Branch if Plus                           | if (N = 0) then<br>PC    | <b>←</b> | PC + k + 1 | None | 1/2 | 1/2 | 1/2 | 1/2 |
|------|---|------------------------------------------|--------------------------|----------|------------|------|-----|-----|-----|-----|
| BRGE | k | Branch if<br>Greater or<br>Equal, Signed | if (N ⊕ V= 0)<br>then PC | ←        | PC + k + 1 | None | 1/2 | 1/2 | 1/2 | 1/2 |
| BRLT | k | Branch if Less<br>Than, Signed           | if (N ⊕ V= 1)<br>then PC | <b>←</b> | PC + k + 1 | None | 1/2 | 1/2 | 1/2 | 1/2 |
| BRHS | k | Branch if Half<br>Carry Flag<br>Set      | if (H = 1) then<br>PC    | ←        | PC + k + 1 | None | 1/2 | 1/2 | 1/2 | 1/2 |
| BRHC | k | Branch if Half<br>Carry Flag<br>Cleared  | if (H = 0) then<br>PC    | ←        | PC + k + 1 | None | 1/2 | 1/2 | 1/2 | 1/2 |
| BRTS | k | Branch if T<br>Flag Set                  | if (T = 1) then<br>PC    | <b>←</b> | PC + k + 1 | None | 1/2 | 1/2 | 1/2 | 1/2 |
| BRTC | k | Branch if T<br>Flag Cleared              | if (T = 0) then<br>PC    | <b>←</b> | PC + k + 1 | None | 1/2 | 1/2 | 1/2 | 1/2 |
| BRVS | k | Branch if<br>Overflow Flag<br>is Set     | if (V = 1) then<br>PC    | ←        | PC + k + 1 | None | 1/2 | 1/2 | 1/2 | 1/2 |
| BRVC | k | Branch if<br>Overflow Flag<br>is Cleared | if (V = 0) then<br>PC    | <b>←</b> | PC + k + 1 | None | 1/2 | 1/2 | 1/2 | 1/2 |
| BRIE | k | Branch if<br>Interrupt<br>Enabled        | if (I = 1) then<br>PC    | <b>←</b> | PC + k + 1 | None | 1/2 | 1/2 | 1/2 | 1/2 |
| BRID | k | Branch if<br>Interrupt<br>Disabled       | if (I = 0) then<br>PC    | ←        | PC + k + 1 | None | 1/2 | 1/2 | 1/2 | 1/2 |

24